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بو سلمة الحسن بن ممد العريان بن حسن بن رزق بن ٳبراهيم بن حبيب 
- ساحه الله - 


0 ھ 


جيع الحقوق محفوظة لعموم المسلمين 


بسم الله الرمن الرحم 


المد لله رب العالين الرحن الرحم مالك يوم الدين رب السموات والأرض وما ييهها ورب المرش المظم ا ممم الوهاب 
القوي التواب مجري السحاب وقاهر الأحزاب والصلاة والسلام على النبي المبعوث رحمة للعالمين سيد الأولين والآخرين 
وخاتم النبيين وقائد الغر الحجلين المرسل من قبل ربه بشيرا ونذيرا وداعيا إلى الله بإذنه وسراجا منيرا وبعد : 

فلا کان من الأهية كان تنظم عملیات البيع والشراء وتنظم حالات العاملين في عين من الأعين التجارية سواء كانت آم 
إدارية أو اجتاعية أو ما سواها ما يستلزم عمليات التدوين لحالات أو أشخاص أو بضائع أو ما شابهها لتفتظم بالعلم بها 
الأمور ويعام الريوح من الخسور والوارد من الصادر والمهمل من التزم وجدت تقنية قواعد البيانات مذ بضعة أعوام لكي 
تغطي هذه الاحتياجات الياتية على اختلاف ألواما من قواعد بيانات صغيرة للشركات والمؤسسات ضئياة المعاملات 
وغرهاكيرة للمؤسسات الكبرى والمشاريع العملاقة ولا ينحصر أمر هذه القواعد في العمليات الشرائية والتجارية فقط فن 
استخداماعما أيضا المشاريع العلمية التي تتطلب تخزين ك من البيانات عن حالة مرضية معينة أو حالة عنصر طبيعي معن من 
عناصر الطبيعة وقد تستخدم في الأمور الإدارية لتنظيم حركة الموظفين في مكان ما وهكذا ستلحظ أا قد استحوزت 
على كير من الجالات وفرضت نفسها في عالم التقنية والبرجيات ما جعلها من الأبواب اللازمة التدارس في علم البرجة ولقد 
عزمت النية والقصد وبالله الاستعانة وإليه الأمر أن أفصل في هذا الباب في کتاي قراج الكرب فيا خفي من معا الي 
شارب ثم ارتأيت آن الوقت قد يضيق ببعض الأصحاب أن يأخذوا عني هذه الدروس - يعني الاثفراج - فعجلت بهذه 
ارسالة التي قصدت فيا استجاع ما وجب علمه لمن أراد المعرفة في هنذا الباب من عمليات إدراية من إضافة للبيانات 
والسجلات وإزالة لها والتتقل من خلالها بتتيح ومنه أيضا عمليات البحث والعصفية للبيانات وسيأني التبيين في مغل هذه 
المسائل وقد اعتقدت في رسالتي هذه كغيرها من الرسائل منج قوالب النوافذ مخلفا لوحة التحك كاتجاه يلمي ارتضيته في 
هذا الفرع من العلوم ولعلي أفرد فيه مبحثا خاصا ما لهذا تجاه من مشالب على مرتاديه نييما إن شاء الله بإسهاب لكيلا 
يبقى ني حجة حة في المنالغة عن هذا تجاه فالبقاء في عالم العلوم للأصح والأجدى والوقت عنصر هام لا ينبغي أن بهدر 
إن آمكن استغلاله والعلم متاح احير لا ينبغي جمله إن آمكن اقنتاؤه فتأًمل ! 

هذا والله أسأل أن ينفع برسالتي هذا خلقا مم فيا حاجة وألا بجعل لضيق العطن فما لمقام ارتقاءا وأن يبق لها في آذهان 
الناس أثرا مادام مم فيا نقع وأن يبتها علامة لحبة رب العباد مادامت فقيرة من الشر والضر والله المستعان . 

اعم - رحمك الله تعالى - أن هذه الرسالة تحوي خمسة مسائل ذكرها ههنا في تتابع لكي حيط القاريء محتوى الرسالة 
فأول المسائل في إنشاء قاعدة بيانات وكفية ضبط الأعمدة وعمليات الترقم الناتية وماهية البيانات المسموح لھا في کل عامود 
مم ثنيت المسائل بواحمة مستخدم بسيطة يراد بها توضيح المقصد وبيان كل أمر برجي وكيفية ربط هذا العطبيق الحاوي 
للواححمة بقاعدة البيانات التي أفشأناها في المسألة الأولى م تكلم عن كيفية إضافة البيانات من خلال صندوق نص أو أكثر 
ثم كانت ثالعة الأاي في كيفية استرجاع البيانات من قاعدة البيانات وإظهارها للمستخدم . 


أما الرابعة فنتكلم فيها عن كيفية تصفح البيانات سواء بطريقة تتابعية أو بالنظر في آخر السجلات وأولها ثم الحخامسة في 
كيفية تحديث البيانات في جموعة عرض البيانات وسيأتي تعريف ذلك والتفصيل فيه كصطلح ثم كانت السادسة في كيفية 
إزالة البيانات مع التحديث وبدونه والفرق ينها وأهية هذه العمليات وأما المسالة السابعة ففي كفية تصفية البيانات إلى 
بيانات ذات صفات مددة فكل هذا يأتيك علمه في هذه الرسالة الختصرة وفها كا ذكرنا آنفا واجبات هذا الفرع وأعني 
بواجبات الفرع يعني ما لا يسع مله لن له اهتام بهذا الباب من العلم فلا يستقم عقلا أن يزع إنسان أنه بدري ما قواعد 
البيانات وكيفية إنشانما إن لم يكن قادرا على تنفيذ ما أمميه بالعميات الأساسية في قواعد البيانات يعني الإضاقة والإزالة 
والتعديل والتصفية والبحث فهذه عمليات لا يكن آن تجهل وسيأتي بيان كل جزء والله المستعان . 

أقول مستيعنا بالله وحده . لكي تفذ جموعة المسائل التي ستذكر هنا تباعا لابد أن يكون لديك بيئة التطوير للسي شارب 
الموسومة بالفيجوال سي شارب إكسبرس للعام ألفين وثانية آم ما شابهها من الإصدارات وأما بالنسبة لمبرجي السي بلس 
بلس فسيحتاجون إلى بيئة إدارة خادم الإس كيو إل الموسومة إبكليزيا بإس كيو إل سيرفر مانجمنت استوديو والتي تعاح 
جانا للتحميل من على الموقع الرسمي لمايكروسوفت فإتإتقس هناك ! 

لمسألة الأولى في إنشاء قاعدة البيانات وعملية الإشاء هذه انقسم فها المبرجين إلى فريقين بعضهم يقوم بإنشاء قاعدة 
البيانات بلغة الإس كيو إل عن طريق كنابة ترميزات معينة كشل إفشاء قامُة من البیانات مثلا تسمی بتایبل ٤1ط1۹‏ يقوم 


: بعض المبرجين بإنشامما هكذا‎ 
USE MyDataBase 
GC 
CREATE ADEL : 


ID INT IDENTITY NOT NULL, 
هذه عبارة عن ترميزات لإفشاء قامُة بيانات سميناها عادل تحمل عنصرا واحدا تعريفيا اسميناها آي دي 12 کا هكن تفهم‎ 
ذلك من الترميز أعلاه‎ 
ولكن هذه الطريقة ليست ما أرتضيه للأصحاب لما وفرته مایکروسوفت في أيامنا هذه من تسهيلات في عمليات إنشاء‎ 
جديد على نظام قوالب النوافذ ثم إنشاء قاعدة ببانات بالضغط بزر الفأرة الأمن على اسم المشروع ثم إضافة عنصر جديد ثم‎ 
إضافة قاعدة بياناتية غير حلية لكي يتسنى تنفيذ محتوى هذه القاعدة على تطبيقات شبكية الموسومة بالويب أبليكيشن‎ 
. ههنا‎ 
يجدر إلى الإشارة ههنا أيضا إلى تبيه هام قبل المضي قدما في هذه المسألة وهو التحذير من تغيير الامتدادات في أسماء‎ 
قواعد البيانات المنشأة حديغا عند إرادة تغيير اسمها لأن الامتدادت في العناصر المضافة حديغا في الفيجوال سي شارب لا‎ 
يتم إكمالها تلقائيا من جمع الترميزات أو من بيئة التطوير ولعل هذا يكون عيبا من جانب وقد يرتئيه آخرون مزيدا من الفقة‎ 
. وايقكين للمبرمج المستخدم في إنشاء ما جلو له من عناصر وأنا لا أميل إلى يها فالأمر فيه سعه‎ 


كما رى في الشكل المقابل قنا بعملية إضافة عنصر 
جديد لاحظ أننا ضغطنا على اسم المشروع وليس اسم 
ا لمل ثم قا بإضافة عنصر جديد وعلى الرم من أن 
هذه اميزة لا تتواجد في بيئة تطوير الفيجوال سي بلس 
بلس إلا أنه كما تقدم الكلام عليه يكن أن قوم بإنشاء 
قاعدة بيانات عن طريق الإس كيو إل مانجمنت 
استوديو Management Studio)‏ اSQ)‏ وسقعرض 
بإذن الله تعالى لهذا الجزء لاحقا . 

في حال وجود قاعدة بيانات منشئة مسبقا داخل أو 
خارج بيقة رميز السي شارب يمكنك اختيار إضافة 
عنصر فعلي وهو الاختيار الثاني الموسوم إنكليزيا بهذا 
الشكل la . Exsisting Item‏ الاختيار یظهر قعه ف 
حال إفشاء تطبيقات برجية بقواعد بيانات تم تنفيذها 


ا E‏ العا تھ | تا 


project]‏ 1( دا س ' Solution‏ ا 


Build 
4-Ê ف اك‎ Rebuild 
- Î Form Publish... 
کک‎ i Î Prnnrd 
î] Newkem... Add 
[iî] | Existing Item... Add Reference... 
[j | New Folder Add Service Reference... 
3 Windows Form... Set as Startllp Project 
ا‎ User Control... Debug 
A | Class... ا | ل‎ 
i | Paste 
Properties Eee 
RandomProject 8 Eã Propel e 


2 PIE 


فعليا بشكل مسبق سواء عن طريق بيئة التنفيذ للسي شارب عند الضغط على الاختيار الأول سيظهر لك الشكل 


العالي : 


ا 


Kw 


Visual C# Items Visual Studio installed templates 


P 
nfigurat... Manifest File E 


7 


Debugger Treat LINQ to SQL Local 
Visualizer Classes Database 


Co 


MDI Parent Resources Service-base Settings File  TextFile User Control 
d Database 


Entity Da... 


Add New Item - RandomProject 
Categories: Templates: 
XNA Game Studio 3.0 


XNA Game Studio 3.1 
About Box ADO. 


¥ 


a @ 


Code File DataSet 


Form File 


اڪ 


An empty SQL Server database for service-based data access 


Name: Databasel .mdf 


کا ترى ههنا اخترنا إشاء قاعدة بيانات مبنية على ساس خدي ٩4ط ٥۲۷1٥١‏ لي پتسنی استخداماها فی تطبيقات 
شبكية كا سبق النبيه عليه عند تسمية قاعدة البيانات لا تسى عدم تغيير الامتداد فهذا جدير بتكرار التنبيه عليه فليعل 
عند الضغط على زر الإضافة الموسوم إتکلیزیا بآد Add‏ سغظهر لك رسالة یطلب منك فا احتيار عناصر قاعدة البيانات 


وهذا لا يتأتى قعه إلا إذا كانت قاعدة البيانات سابقة الإنشاء وبالتالي فسنتجاهل هذه الرسالة فقط بالكبس على زر الإلغاء 


الرسالة شكلها كا يلي : 


LL Choose Your Database Objects 
له‎ 1 


Which database objects do you want in your dataset? 


any objects, Click Finish to cı RRS 


or does nat cC 
adde: i اا و ا ا‎ n the Dataset Designer to ا‎ e the 
data 


Data Source Configuration Wizard 


کو کے 


yeaa se you 0 
Once e object 


DataSet name: 
Databasel DataSet 


عند إلغاء الرسالة سعلحظ أنه قد اضيفت لديك في قامة المشروع الخاص بك أيقونة تعبر عن قاعدة بيانات كما في الشكل 


التالي ههنا هذه الأيقونة تعني أنه قد إضافة ملف قاعدة البيانات في جلد ۾ 


المشروع الحاص بك ولرما لا كن مطوري الني بلس بلس من مارسة 
هذه العملية على هذا الشكل إلا أا ندرج ههنا كفية إضافة قاعدة بياناٽت 
للبيثة السي بلس بلس وما سيلي ذلك من الترميزات المتعلقة بعمليات 
Ek eS‏ ع اسي 
إذن الله تعالى ٤‏ 

الآن وقد أفشأنا قاعدة بيانات مكنا أن ننقل إلى بيئة إدارة خادم الإس ك 
إل لرى كفية إفشاء قاعدة بيانات هناك والتي ستلحظ فہا تشاہا کبیرا 
يعني في عمليات تعريف الجداول ونعني بتعريف ال جداول وضع الخانات 
اللازم ملؤها في حال إدخال البيانات فهذا کله يأتيك بیانه . 


salı ado 


‘Solution Explorer - RandomProject IHX 
8 BE 


[gg] Solution 'RandomProject’ (l1 project] 


3 E 


F- Êd] Properties 


H- &] References 

i: ۲ Databasel.mdf 
¥ Databasel_log.ldf 
i: EE] Formi.cs 

۰ 3% Forml.Designer,cs 
2 Forml,resx 

i... BH Program.cs 


أمر آخر لا بد من الإشارة إليه هنا وهو آن اني سيازم مبرمج لغة السي بلس بلس فقط من الإس كيو إل استوديو هو 
جرد امتداد قاعدة البيانات التي أنشأها من خلال والني سيقوم باستخدامه لنقل قاعدة البيانات المفشأة من الجلد الخاص 
بها في خادم الإس كيو إل ثم سيستخدم الامتداد الجديد في التعامل مع قاعدة البيانات وكل هذا ياتي تباعا بأمر الله تعالى 


وحده ۰ تأمل الشكل التالي : 

سنقوم بالضغط بزر الفأرة الان على جلد قواعد البيانات 
ا لموسوم بالداتا بايزز sءءةط11ه(‏ ثم اختيار عملية إفشاء قاعدة 
بیانات جدیدة کا هو موت في الشكل المقابل وقد يقول قائل : 
اذا ا بإ إضافة فس الخصائص الميسرة لعملية إفشاء قواعد 
انات في ية تطوير السي بلس بلس كا هو الخال في السي 
شارب ؟ 

فا جواب وهو ليس اعتذارا عن عبوب تطوپر مایكروسوفت إلا 
أتتي اعتقد أن هذا سببه المستوى البرجي للمبرمج بلغة الي 
الس الس عن مع التي شارب و الفل لظ أن ب 
تطوير الفيجوال يسيك تحوي خصائص أكار في إضافة المناصر 
منها في لغة السي شارب ولكن هنا إن صح فليس عذرا فكون 
المبرمج محترفا أو قرسا أو حتى يبغي اإقرس على لغة برجية قوية 
في تطبيقاتها وترميزاتها إن ذلك لا يعني أن تكون الأدوات الموفرة 
له في هذا الباب عسيرة الاستخدام والتعامل معها فهذا بكل 
حال ليس عذرا وأميل إلى خطا هذا تجاه فليعام ! 


I Microsoft SQL Server Management Studio 


File Edit View Tools Window Community Help 


TÎ New Query ا‎ EF El 

Object Explorer + % 

Connect” 3; 4} 2 8 

2 7 BIG-ALNSQLEXPRESS (SQL Server 10.0.2531 - | 
EF | Datalkasae 

E 

HA Û Secu Aitath 
FH LA Serre 
EA LA Repli 
Hl Û Mang 


Restore Database... 
Restore Files and FilegroUps... 


Start FowerShell 


Reports 


Refresh 


عند الضغط على اختيار إنشاء قاعدة بيانات جديدة ستظهر لك نافذة لكى تحدد من خلالها تسمية قاعدة البيانات الجديدة 


أسميناها ههنا بحمزة تأمل الشكل التالي : 

عند الاتهاء من تسمية قاعدة البيانات 
الجديدة في أعلى صندوق نصي اكبس زر | 
الموافقة 0K‏ لا زر الإضافة ستلحظ أنه 
قد تم إنشاء ملفين أحدها بجوي البيانات 
الفعلية في قاعدة البيانات المنشعة حديها 
والثاني يسمی بالسجل 1٥١‏ والذني يحوي 
حالات الاتصال والانفصال عن قاعدة 
البيانات تيك وكبتديء لا أنصحك بالقلق 
كهيرا بالنسبة لبقية الحيارات المتاحة في 
هذه النافذة فلكل مقام مقال ونحن بصدد 


فسح أبواب هذا الع لضيق الوقت في أ 1 == ا0_ 


„„Intial Size (MB) „Puta growth 
Mi 


By 
Not Applica. . 1َ By 10 pı 


Es: 
1 lame File Type Filegroup 
Rows ... PRIMARY 


المجال ومن اراد الاستزادة فعليه بالانقراج سر الله إقامه آمین : 

عند الضغط على زر الموافقة سيظهر لك في القائُة الفرعية على اليسار اسم قاعدة البيانات يظهر بجانبه علامة المع + عند 
الضغط علا يتفرع لديك جموعة من الجلدات الحاصة بقاعدة البيانات تيك وهنا نعود إلى مرجي لغة السي شارب نو 
كيفية إنشاء جداول أو قوائم بصفات معينة وعليه فالشكل الأين - بالنسبة للقاريء - يوضع شكل القامة الخاصة بقاعدة 
البيانات المنشعة في بيئة تطوير السي شارب هذه القامة تظهر على اليسار عند الضغط بر الفأرة الأيسر مرتين على أيقونة 
قاعدة البيانات المضافة مسبقا انظر الشكل الرابع فيا سبق . وأما مستخدي السي بلس بلس فسيكون الوض ع كا هو لن 
تظهر قوائم جديدة سيظل العمل في نفس المنطقة التي أنشأنا فما قاعدة البيانات كما هو في الشكل الأيسر تأمل الشكلين 
المتقابلين . 


lz Microsoft SQL Server Management Studio E RandomProject - Microsoft Visual C# 2008 Express 


File Edit View Tools Window Community File Edit View Project Build Debug Data 
J. New Query | j | lè | 2ه د # ا و ج‎ © - £ 
Object Explorer + HH ¥# 

Connect 2 3 

Lan 2| Database Explorer ¥ H %*‏ ا کا 


ÎB BIG-ALRSQLEXPRESS (SQL Serwer 10.0.2531 - |‏ ا 
Û Databases‏ 2 
IH Û System Databases‏ 
hamza‏ ۲ 5 
E Û Database Diagrams‏ 


E1. [jJ Data Connections 
E liç Databasel.mdf 
H.- J Database Diagrams 


|seanos E}E 1| (OTO 


0 
tH a] View| Add New Table | 
1 - ll Store New Query 
EH. Func 
Start PowerShell .- Ê Synd ك‎ 
EFS - Type Î Properties 
H.- N Assemblies 


Hl la Security Refresh 
3 Server Objects™ 

+ Ld Replication 
3 Management 


کا تری يوجد لدينا ههنا نوع من التشابه بين هذه وتلك وتعمدت إبقاء شريط العنوان في الصورة المقتنصة لكيلا بحدث 
الاشتباه والخلط على القاريء وعليه فأقول مسخعينا بالله : عند الضغظ على اختيار اضافة جدول جديد سيظهر لك 
جدول في منتصف بيئة العمل سواء في السي شارب أو الي بلس بلس تطالب فيه ملء ثلالة خانات رئيسية هذه 
الحانات هي اسم العامود ونوع البيانات المدخلة فيه والسماحية بترك هذه الحانة فارغة عند إدخال البيانات بالنسبة 
للمستخدم آم لا حیث أنه لا بخنى أن بعض الحانات في قواعد البيانات لا يسع تركها فارغة كا لو أنشأت قاعدة بيانات 
تحمل بيانات عملاء مثلا فلا يسع بكل حال أن يسمح للمدخل- بضم المم وكسر الخاء - للبيانات بان يترك هنذا الحقل عملا 
أو فارغا بينا يكن السماح قول أخرى بتركها فارخة كرمم البرق مثلا الموسوم بالفاكس وما أشبه ذلك تأمل الشكل التالي: 


„dbo. Table: Tab...\DATABASE1.MDF)* ( Forml.es [Design]êl Start Page! > ¥ 


Column Name Data Type Allow Nulls 
ID int E 
FF llsername nchar(l0) El 


timestamp ڪ‎ 


tinyint 
uniqueidentifier 
varbinary(50) 
varbinary([MAk] 
varchar(MAX) ِ 


xml 


کا تری ههنا قنا بإضافة اسم آي دي 12 للحقل الأول وم سمح له بأن ترك فارغا بنا أفشانا حقلا آخرا آسمینا باسم 
المستخدم وأسقطنا قامة بنوع البيانات المراد إدخالها في هذا الحقل ولنا عند هذه العملية وقفة فإذا كت حديث العهد 
بالتعامل مع قواعد البيانات فأنصحك باستخدام النوع varchar‏ لان هذا انوع يحمل تقريبا جيع ما مکن آن يدخله 
المستخدم من بيانات من أرقام وأحرف ورموز خاصة كعلامة آت ‏ المستخدمة في البريد الألكتروني والعلامات العلمية 
المستخدمة في المعادلات الرياضية كألفا ويبتا وسيتا وما إلى ذلك من العلامات التي تحتاج إلى معرفات خاصة . 

وعليه فبنفس الشكل سنقوم بإفشاء حقل آخر سنسمیه بكلمة السر ۲45۷0۲۵ وسنضع له نفس نوع البيانية كسابقتها . 
قد يقول قائل : وفيم انشأنا حقل التعريف آي دي إذاكانت احتياجاتنا مثلا في اسم المستخدم وكلمة السر فقط ؟ 

فا جواب : هو أننا سنستخدم هذا الحقل فا بعد لكي نحدد مؤشرا على كل سطر من سطور البيانات وسنعاود العذكير 
بهذه النقطة لاحقا بإذن الله تعالى . 

عند الاتهاء من إدخال أسماء المحقول المراد ملؤها يفترض أن يكون الشكل الهائي للجدول على النحو التالي : 


الآن تعال نذكر أمرا هاما جدا فها يتعلق بحقل 


BIG-ALNSQLEXPRE...za - dbo.Table_1* 


التعرد یف ا آي دي ف تعرڊ یف الجد و ل Column Name . Data Type Allow Nulls‏ 
ID in‏ 

المقابل يمكنك أن نعل هذا | لمحقل لا تلقائیا WsernamE varchar 50} E‏ 
Password varchar (50) ۳2‏ 


بدون تكليف المدخل للبيانات مشقة إدخال 


۴ 


ر جديد عند إدخال بيانية ما وهذا عن 

طريق التأشير مؤشر الفارة على خانة التعريف آي دي سيظهر أك في الأسفل جموعة من السطور التي تعبر عن خصائص 
هذا الحقل هذه الجموعة توسم إنکلزیا بکولومن بروبیرتیز e۲٤1e5‏ م٥۲‏ ۸اه في هذه الجموعة ستجد علامة المع + 
بجانب بعض هذه السطور سنختار منها سطر تحديد الهوية ١٥ناةءا1۴ءمS‏ رانا عند الضغط على علامة المع 
المقابلة لهذا السطر سيظهر لك سطرا فرعيا يسمى بإز آيدنتيتي entity‏ ءا هذا السطر سنقوم بالضغط على الخانة 
المقابلة له والتي تكون فيهاكلمة نو ١٥‏ يعني تفي التعديد الناتي للبيانبة الجديدة سنقوم بالنقر بزر الفأرة الأيسر عند هذه 


الانة وتحويلها إلى الإبجاب الموسومة بيس ۲5 من شأن هذه العملية أن تقوم بتحويل الخانة المقابل للسطر الأصلي إلى 


: تقس اة تأمل الشكل التالي‎ 
BIG-ALNSQLEXPRE...za - dbo.Table_1* E 
Column Name Data Type Allow Nulls 
i int Bl 
varchar (50) Wl 
archar (50) 1 
Hl 
int 
No 
31 Identity Specification No 
(ls Identity) No اا‎ 
Iden crement Yes = 
No 


عند تحويل التمة إلى الإيجاب سخلاحظ التغيير الذي تكلمنا عليه سابقا من شأن هذه الخصيصة أن تتحمل عن المدخل 
للبيانات عملية إدخال الرة غ التعريفي أو رة هوية السجل في كل مرة يم تم فا إدخال “جل جديد وكل هذا يشتبه فيه التعامل 
مع قاعدة البيانات المنشئة داخل بيئة تطوير السي شارب وقاعدة لیات المنشئة عن طريق بيئة إدارة خادم الإس كيو إل 
النسبة لري المي باس باس يبت لديك آمرا أخيرا في حلية تصمم اج دول أو القائة وهو تسميها لاحظ أن هناك 
فرق بين اسم قاعدة البيانات التي تحوي الجدول وبين الجدول أو الجداول نقسها وعليه عند الضغط على زر المحفظ أعلاه 
الذي يكون شكله هكذا طا سيظهر لك رسالة طلب تسمية الجدول الني أنشأًنا فيه المانات - تسمى علية تعريف 
الجدول - تأمل الشكل التالي : 


سڏسمي الجدول مغلا ماي ایل MyTable‏ ولتضع هذه | Choose Name‏ 
الأساء ك ف بال لأا سنا ارقا فا ۴ فانتبه و 


وعليه فهذا إذا محتوى المسألة الأولى . فإذا علمت ذلك | ممت ) 
فلتأخذ في المسألة الثانية في عملية الترميز وعند هذه المسألة 


يبد تعاملك فعليا مع الإس كيو إل من خلال الي شارب أو السي بلس بلس فاقول بأمر الله تعالى : 

اعم - وفقك الله تعالى - أنك ستحتاج قبل البدء في تعليق السي شارب أو السي بلس بلس بالإس كيو إل آن تستدعي 

اسم مساحة خاص بالإس كيو إلى ولن تحتاج أن تضيف أية مكنبات نظرا لأن ا مكنبة الفرعية الحاصة بالإس كيو إل إنغا هي 

عبارة عن مكنبة مدجة في مكنبات النظام وعليه ي السي شارب ستقوم بإضافة السطر البرحجي العالي عند مبعدا الترميز 
کا پل : 


أما في لغة السي بلس بلس فسيكون الترميز كا يلي : 
using namespace System::Data::SqlClient;‏ 


هذا الترميز هو عبارة عن عملية استخدام لاسم المساحة الخاص مكنبات الإس كيو إل من أجل أن زقكن من التعامل 
بشکل أسرع مع فئات هذه الكتبة - أرجو مراجعة مسائل أساء المساحات للتعرف على هذه العملية بشكل مستفيض في 
اقراج الكرب - الآن نقوم بعملية اختبار الانصال بين خادم الإس كيو إل وبين الي شارب أو الي بلس بلس في لغة 
السي شارب انقر بزر الفأرة الأين على قاعدة البيانات الموجود في القامة اليسرى كما في الشكل القالي : 

كا ترى في الشكل المقابل سنقوم بالضغظ على أمر تعديل 7 ELT‏ 
ااتصال وإن كما لن نمدل اتصال ف المحقيقة ولكننا ستأخذ E1‏ 


= [JÛ Data Connections 


عنوان قاعدة البيانات لكي رقكن من التعامل معها داخل ترميزات B, E‏ .2 


using System.Data.Sq1Client; 


i. Hw Data) [| | Refresh 1 
û: ا‎ Tablı î | Delete الي شارب زل الضغظ على هذا الأمر سيظهر لك نافذة أخرى‎ 
i - HN 
a. = ا‎ Change View + | سغظھر لك‎ Advanced ستضغط فيا أيضا على زر التقدم‎ 
. DN Store Modify Connection... ا‎ 2 a ا .ا ای«‎ 
t. By Func EEE نافذة جلیده سخأخذ عنوان قاعدة البيانات من أسفلها ي وح‎ 
41 a Syn کا َة‎ 4 ۰ 
f Type New Query ق أمتداد فئه اتصال الإس ج إل سياق بیانه ۱ لک ( العالي‎ 
يوضع عبلية أذ عنوان قاعدة البيانات تأمل الشكل التالي تع فيه | ۲م م ا‎ 
Els 
I | Properties : العمليات من اليسار إلى امین‎ 
EET CT on SSS AEE 
ll | Enter information to connect to the selected data source or click ۳ E False 
f | "Change" to choose a different data source and/or provider. e 
| Data source: e 
أ‎ Microsoft SQL Serwer Database File (SqlClient) Change... ru erverCertificate False 
lÎ Database file name (new or aûsting): ser ID 
ات کیت متم تت اق دم سمت نارق شتا ا‎ AttachDbFilename CN Users\Hassan\AppData' = 
Log oan to the server Context Connecti ion False 
® Use Windows Authentication 
Use SQL Server Authentication 


2 Cut 

copy 

Paste 

Test Connection ok | lSanec | Delete 


Select All 


Right to left Reading order 


Show Unicode control characters 


Insert Unicode control character 


الآن تعال نستخدم هذا العنوان الني فسخناه في فئة الاتصال بالإس كيو إل - لا زلنا في ترميز الي شارب - بعد النقر 
مرتين على القالب لكي نضع هذا الترميز داخل دالة تحميل القالب تأمل الترميز التالي : 


private void Form1 Load(object sender, EventArgs e) 


SqlConnection sc = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User 
Instance=True"); 


1 
قنا بتعريف عنصر أسميناه إس سي من فئة اتصال الإس كيو إل ثم وضعنا في العنصر الجديد عنوان قاعدة البيانات مع 
بعض التفصيلات الاصة بالإس كيو إل كمظام الماية وإمكانية استرجعا البيانات وما إلى ذلك من التفاصيل التي لا بحسن 
التعمق فيا ههنا . ثم لاحظ أنك قد تحتاج إلى وضع بعض التعديلات في النص المنسوخ لذلك أنصحك بقابلة الترميز أعلاه 
بترميزك لكي تعرف مواطن التشابه والاختلاف لضان صحة الترميز . 
في لغة السي بلس بلس بعد حفظ الجدول باسم ماي تایبل کا قلنا سالفا سنستجذب عنوان قاعدة البيانات بطريقة غختلفة 
ستجد أن قاعدة البيانات محفوظة غالبا في امتداد مثل هذا : 
C:\Program Files\Microsoft SQL Server\MSSQL10.SQLEXPRESS\MSSQLIDATA‏ 

داخل الجاد الأخير ستجد ملفين بيان إلى تفس امم قاعدة البيانات التي أنشاتما من قبل أسميناها ههنا بجمزة ستجد 
ملفين أحدها اسم hamza.mdf‏ والآخر |مa û hamza_log.1df‏ بنسخها وضعها في جلد المشروع الحاص بك في 
السي بلس بلس شم خذ عنوان الملف الأول بعد وضعه في مجاد المشروع وضعه على هذه الصيغة داخل دالة تحميل القالب 
على الشكل التالي : 

private: System::Void Form1 Click(System::Object sender, System::EventArgs? e) { 


SqlConnection? sc = gcnew SqlConnection("Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User 
Instance=True" 


قد يتسر على بعض مرجي الي بلس بلس قل قواعد ايلات المنشتة ممن جا اللات الخاص بالحادم إلى آية جلد 
آخر إذاكانوا من المستخدمين لنظام التشغيل فيستا أو سيفن وعليه قمكهم إنشاء قواعد بيانات غير ية عن طريق 
بيئات تشغيل السي شارب ثم تقل هذين اللفين الذين سبق التنبيه عنها إلى جلد مشروع السي بلس بلس وإن كانت هذه 
الطريقة غير احترافية وماكان من شأن مبرمج السي بلس بلس أن يلزم - بضم الياء - بتثبيت بيئة لغة برمجة لا يستخدعا 
إلا ننا نذكر هذا فقط لن ابتدأً هذا الطريق على ظن مني ألا تتعسر عليه عملية التعامل المباشر مع خادم الإس كيو إل حتى 
بدون نقل ال لفات وما شابمها وإنغاكان نقل ال لفات نجرد إمكانية التنقل مجاد المشروع بين حاسوب وآخر دون حدوث أية 
تقصيرات في آداء البرنامج فليعل . 

الآن تعال نختبر عبلية الاتصال بحيلة برحجية بسيطة في التدفيذ وهي إظهار رسالة عن حالة الاتصال بين أمر فتح الاتصال 
مع قاعدة البيانات وأمر إغلاقها تأمل الترميز التالي في لغة السي شارب سيكون الوضع هكذا : 


private void Form1 Load(object sender, EventArgs e) 


SqlConnection sc = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User 
Instance=True"); 

sc.Open(); 

MessageBox.Show(sc.State. ToString0)); 

sc.Close(); 


نا ھھنا بفتح الاتصال عن طريق الأمر pen‏ 0.ءء ثم أظهرنا رسالة عن حالة الاتصال ا قشل في العنصر سي إس مم اغا 
اتصال بالأمر ءء٥1٤.ءء‏ إذاكان ااتصال سلها سعظهر لك رسالة قبل ظهر القالب فهاكلمة ١٠ص0‏ أما ما سوى 
ذلك فتظهر لك رسالة تخطرك بىشكلة ما في الاتصال . 
هذه الخطوة تعتبر أساسية جدا لأنه على أساس هذا التصال تم جيع عمليات التعامل مع قواعد البيانات وبالتالي فلابد أن 
اكد قبل البدء في كنابة ترميز أية عمليات أخر من أن الانصال سلم لا إشكال فيه في لغة السي بلس بلس سيكون 
الترميز على النحو التالي : 

private: System::Void Form1 Click(System::Object sender, System::EventArgs? e) { 


SqlConnection? sc = gcnew SqlConnection("Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User 
Instance=True"); 

sc->OpenÛ; 

MessageBox::Show(sc->State. ToString0)); 

sc->CloseQ); 


بالنسبة برجي السي بلس بلس ستلحظ أنه لن تخرج لك قاة اختيارية عند وضع نقطة بع دكلمة ٥اا‏ لی تخار عبلبة 
التحویل إلى وتر ٠٠5۲۲1٣2‏ ستضطر إلى كتابتها بنفسك وهذا يعد عيبا في بيئة التشغيل ترجو الله تعالى أن يتم تعديله في 
فسخة العام ألفين وعشرة ولا أدري ما إذاكان الوضع بالمعل في الفيجوال استديو النسخة الاحترافية للعام ألفين واي ة أم لا 
فلا ينبغي التعميم بكل حال للأهية ! 

إذا ظهرت رسالة 0٠١‏ وتأكدنا من صحة اصال نبد إذا في المسألة التالية بأمر الله تعالى وحده وهي في إضافة البيانات 
داخل قاعدة البيانات وعليه فسنقوم بإدراج صندوق نص وزر داخل القالب لكي يتم من خلال صندوق النص إدخال قم 
جديدة لاسم مستخدم وكلمة مرور ثم تنفيذ أمر الإضافة بالزر . 

لاحظ ننا لن تظهر لنا التتائ في القالب عند هذه المرحلة وأكن عندما عرض إلى الجدول 1لقتراضي الموسوم إنكليزيا 
بالداتا سيت 56 112( فإننا سنتعام كيفية إظهار النتاج فيا واسترجاع المعلومات من خلالها والتحديث وما شابه ذلك من 
العملیات کا سيأتي بإذن الله تعالى . 


إذا من المغترض أن يكون قالب تصميم البرنامج على الشكل التالي : 
من الحسن ههد الإشارة إلى أن تصميات التوالب غير على حسب 
نوع البيانات المدخلة وعلى حسب احتياجات المشروع المراد إنشاؤه 
فبعض صناديق النصوص قد تکون كبر من بعض وقد تدل البیانات 
عن طريق صندوق الجموعة ×080 ط٠٠٥‏ وقد تدخلها عن طريق 
صندوق التار أو ما سوى ذلك من المدخلات على حسب المشروع 
فتأمل !. 
الآن نحتاج إلى إضافة بعض الترميز وتعديل الترميز القدتم لكي قكن 
من إضافة ما هو بداخل صندوق النص إلى قاعدة البيانات 
الأساسية وعلیه فسنشرح ههنا جموعة الأوا مر التي سنضعها داخل دالة 
هذا الزر لكي رتقكن من فهم كيفية مرور الأوامر في الترميز . أقول مستعينا بالله تعالى : 
الأمر الأول في تعريف عنصر من فئة تحويل البيانات ونحتاج هنا العنصر من تيك الفئة لكي يتم تحويل البيانات من 
صندوقي النص إلى قاعدة البيانات وبالمكس فها سيلي من المسائل تأمل الترميز التالي في لغة السي شارب سيكون الوضع 
هکذا : 


أما في لغة الي بلس بلس فسيكون الوضع هكذا : 
SqlDataAdapter? da = gcnew SqlDataAdapter();‏ 


هذا الترميز السابق سيكون بثابة الجسر الذي تعبر من خلاله القم من القالب إلى قاعدة البيانات ومن قاعدة البيانات إلى 
القالب ولكن كا أنك لا يكنك أن تدخل بلدة ما مثلا وتتعامل مع أهلها بدون أن تدرك لغتهم فبا لمعل لا كنك ههنا أن 
تدخل البيانات في قاعدة الإس كيو إل إلا إذا أخبرت لاس كوا إل بلغتها أنك تريد إدخال كذا وكذا من الأوامر كشل أمر 
إدخال يالات مغلا وبالتالي سنحتاج | استخدام الجسر هل من أجل التحادث م الاس کيو إل بلغتها سنكتب في الي 
شارب ویتبعها ترمیز الي بلس بلس بالشکل التالي : 


da.InsertCommand = new SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", E 


SqIDataAdapter da = new SqlDataAdapter(); 


da->InsertCommand = gcnew SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
أخرجنا من الدي إيه خصيصة آمر الإدخال ثم عرفنا عنصرا ضمنيا من فئة أوامر الإس كيو إل وضعنا داخله أمر مكثوب‎ 
بلغة الإس كيو إل لكي يفاوض قاعدة البيانات في إدخال البيانات الجديدة من خلاله وفي الهاية ذكرنا عنوان قاعدة البيانات‎ 
. احفوظ في العنصر الذي تحدنا عنه مسبقا إس سي‎ 
لا أرى حاجة في شرح ماكب بلغة الإس كيو إل لأنه بين - بتشديد الياء - عبارة عن عملية إدخال قم لحقل اسم‎ 
المستخدم وكلمة المرور في الجدول المسمى ماي تايبل ولعل الشاهد ههنا هو أهية الاعتناء بأسماء الجداول لأم اكا ترى‎ 
. قد تؤثر في العمليات الأساسية في التعامل مع قواعد البيانات فتأمل‎ 


الآن قد فاوضنا قاعدة البيانات بلغتها التي هي الإس كيو إل في أخذ متغيرات أحدها اسم المستخدم والآخ ركلمة المرور يبقى 
ادينا أن نحدد لهذه المتغيرات المصدر الذي ستأخذ منه تما والتي ستكون صناديق النصوص الموجودة في القوالب تأمل 
الترميز التالي : 
da.InsertCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1. Text;‏ 
da.InsertCommand.Parameters.Add("@Password", SqlDb Type. VarChar). Value = textBox2. Text;‏ 


da->InsertCommand->Parameters-> Add("@Username", SqlDbType::VarChar)-> Value = textBox1->Text; 
da->InsertCommand->Parameters-> Add("@Password", SqlDbType:: VarChar)->Value = textBox2->Text; 


قنا بإضافة الق للمتغيرات الجديدة عن طريق الجسر دي إيه ثم وضعنا اسم المتغير في قاعدة البيانات الذي لابد وأن يقابل 
اسم الانة المدحل فا البيانات ثم حددنا نوع المة فار تشار VarChar‏ راجع المسألة الأو لى في بناء قاعدة البيانات ثم 
اها ا مر اا ا الا ارا مرف اشن ت اله ام فو 
حول البيانات الذي سميناه مجازا الجسر لي ينقل البيانات من هنا إلى هناك يعني من القالب إلى قاعدة البيانات. 

الأن تى عملية فح وقفل الانصال مع قاعدة البيانات وهذه بيناها في الصفحات السابقة ولكن الجديد في هذا الأمر هو اننا 
سنضع بینها أمر الإدخال لكل القم التي م إضافتها عن طريق صناديق النصوص ستجد هذا الأمر في السطر قبل الأخير 
عند استعراض الترميز الهاي لإضافة هة في قاعدة البيانات تأمل في لغة السي شارب سیکون الشکل الہائي هکذا داخل 
دالة زر الإضافة : 


private void buttonl Click(object sender, EventArgs e) 
{ 
SqlConnection sc = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User Instance=True"); 
SqlDataAdapter da = new Sq1DataAdapter(); 
da.InsertCommand = new SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da.InsertCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1. Text; 
da.InsertCommand.Parameters.Add("@Password", SqlDb Type. VarChar). Value = textBox2. Text; 
sc.OpenÛ); 
da.InsertCommand.ExecuteNonQuery(Û; 
sc.Close(); 


في لغة السي بلس بلس سيكون الشكل النهائي هكذا : 


private: System::Void buttonl1 Click(System::Object sender, System::EventArgs? e) { 


SqlConnection? sc = gcnew SqlConnection("Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User Instance=True"); 
SqlDataAdapter?^ da = gcnew SqlDataAdapter(); 

da->InsertCommand = gcnew SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da->InsertCommand->Parameters-> Add("@Username'", SqlDbType::VarChar)->Value = textBox1->Text; 
da->InsertCommand->Parameters->Add("@Password", SqlDbType::VarChar)-> Value = textBox2->Text; 
sc->OpenÛ; 

da->InsertCommand->ExecuteNonQueryÛ; 

sc->Close(); 


} 
الآن غم بإطلاق البرنامج ثم دحل ومتين في صندوقي النصوص ثم اغاق البرنامج وراج جدول قاعدة البيانات سعجد الأمر 
على الشكل التالي : 


E ل‎ Data Connections ۴ 1 اخ‎ aie 


Ê. lk hamza.mdf 
: NULL NULL NULL 
E i Database Diagrams ۰ 
E و‎ Tables 
i E- MyTable 
8 El] ID Add New Table 
ك‎ 2 Us Add New Trigger 
ا‎ e =| Pa? 
f. Ll Views E 
H.. ÛJ Stored Pro Open Table Definition 


E Functions f Show Table Data 
E i Synonyms _, 5 

- Types : 

I. Ê] Assemblie # Delete 


[E] | Refresh 


lied Properties 


ا 


في السي شارب ستضغط بزر الفأرة الأمن على الجدول - وليس القاعدة قسها - ثم اضغط على خيار إظهار بيانات 
الجدول كما في الشكل سيظهر لك التة الجديدة كما ترى . أما بالنسبة للسي بلس بلس فسيكون الوضع هكذا : 


Object Explorer eH x BIG-ALNSQLEXPRE...za - dbo.MyTable 
Connect” | ¥ 1 3 ID Lisername Password 
= Ê BIG-ALNSQLEXPRESS (SQL Server 10.0.2531 - | 1 ahmad atef 
El Û Databases F#¥ NULL MLL MULL 
EH Û System Databases 
E lf hamza 
HE Û Database Diagrams 
El Û Tables 


HH Û System Tables 


SAJ dbo. My jah 
New Table... 


Design 
Select Top 1000 Rows 


_ EditTop200 Rows | _ EditTop200 Rows | A200 Rows 


Script Table as 


View Dependencies 


كا تلاحظ اختلاف طفيف هنا وهناك بين هذا الشكل والشكل الآخر نظرا لأن كلاه ڀزقي إلى خادم مايكروسوفت إس 
كيو إل ولعله من الحسن أن نذكر ههنا أنه لو لم يتم رك عملية ترقيم هوي ةكل “جل إلى الحاسوب لظهر لديك جموعة من 
الأخطاء مفادها أن قاعدة البيانات قد تم تعريفها على وضع الهوية لكل “جل ذاتيا ثم لم يتم إدخال إلا اسم المستخدم وكلمة 
المرور فقط فلابد أن يظهر لك خط تبعا ذلك اا ل ازم سك عا د دا ارك اس با اا 


تعالى فها يلي في بقية العمليات إتت هذه المسألة بحمد الله . فإذا رسخت القدم فما سبق فإليك مسألة في إظهار هذه 
السجلات للمستخدم مباشرة دون الحاجة إلى مراجعة قاعدة البيانات الإس كيو إل انلك سنقوم يإدراج ال جدول القتراضي 
المسمى بالداتا سيت والني آلحنا إليه قبل صفحات قلائل من هذه الرسالة فنقول بأمر الله : محدد البيانات الداتا سيت 
اء 4 هي عبارة عن فئة تابعة لكنبات الإس كيو إل التي تقوم بتعيين جموعة السجلات الموجودة فعليا في قاعدة 
البيانات في ذاكر الحاسوب . ومع هذا التعريف الختصر فإننا سنقوم بوضع محتوى العنصر المعرف من فئة محدد البيانات في 
مظهر البيانات الموسوم بداتا جريد فيو ۷ء۷1 14ا6 14( . مظهر البيانات هو عبارة عن صندوق يظهر في داخاة عحتوی 
قاعدة بيانات معينة سنقوم بوصل محدد البيانات بمظهر البيانات في حين ررغلا محدد البيانات مما بداخل حول البيانات 
المذكرر في المسألة السابقة لا أرى حاجة للكلام عليه مجددا إليك شكلا تثيليا لعملية إظهار البيانات في مظهر البيانات تأمل 
الشكل التالي : 


تحويل البيانات من واجقة المسحخدم تحويل البياتات إلى قاعدة 
البياتات يلحة الإس كو إل 


إلى قاعدة البياتات حول البيانات 
DataAdapter -‏ 


۲ 


SqlConnection DataSet 


دد البياتات 


مظهر اليياتات 


DataGridView 


على هذا الأساس سيتم كتابة الترميزات التعلقة بعملية تنفيذ هذا المشكل ستلاحظ أن العنصر الوسيط في هذه العملية هو 
حول البیانات الذي تم تعريفه مسبقا وعلى الرغ من أن تعريف هذا العنصر من المغترض أن یکون علنيا YJ} Public‏ تي 
آثرت أن يكون كل زر قائم عجموعة التغيرات والعناصر الخاصة به لكي يكتمل شكلية تبادل البيانات في عقل القاريء م 
نظهر البرنامج الهاي بالمتغيرات والعناصر العلنية إذ لا يستقيم تكرار تعريف هذه العناصر آنذاك . 

عند إضافة مظهر العناصر في قالب النوافذ سيكون الشكل الهائي هكذا : 


لاحظ ههنا أننا أضفنا زرا جديدا هو زر إظهار النعا 
وهو الذي يجري فيه الترميز الذي نحن بصدد كمابته | 
ههنا وعليه فالمطلب حاليا هو إنشاء عنصر محدد 
البيانات الداتا سيت لكي يتسنى الوصل بين حول | 
البيانات وبان مظھر البیانات کا ف الرسم امعل | 

السابق تأمل الترميز التالي داخل زر الإظهار : 


Display | | Add 1 


DataSet ds = new DataSet); 


DataSet? ds = gcnew DataSet); 
بعد إنشاء عنصر من فئة تحديد البيانات سنقوم الآن بربط هذا العنصر بمحول البيانات ولكن قبل عملية الربط هذه لابد‎ 
من أن نجعل حول البيانات يحاور قاعدة البيانات من أجل اختيا ر كل السجلات الموجودة في قاعدة البيانات لكي يتم قلها‎ 
جیعا إلى محدد البیانات ومن ثم إلى مظھر البیانات وبالتالی سیتم إدخال ترمیز خاص بالإس کیو إل جدید يقوم باختيا ر کل‎ 
: السجلات الموجودة كا في الترميز التالي‎ 
da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc); 
فنا باستخراج خصيصة فرعية من عنصر مول البيانات هذه الخصيصة تختص بأوامر الاختيار ثم وضعنا أمر الاختيار بلغة‎ 
الإس كيو إل لاحظ أن هذه النجمة * تعني اختيا ركل ما بداخل قاعدة البيانات فلو فرضنا مثلا أا نريد أن نظهر اسم‎ 
: المستخدم فقط دون آية بيانات أخرى فسنكتب الترميز هكذا‎ 
da.SelectCommand = new SqlCommand("SELECT Username FROM MyTable",sc); 
: بالنسبة للترميز في لغة السي بلس بلس فسيكون على النحو التالي‎ 
da->SelectCommand = gcnew SqlCommand("SELECT * FROM MyTable",sc); 
عند هذا الأمر تم إشباع عنصر محول البيانات دي إيه بجميع السجلات الموجودة في قاعدة البيانات الآن نربط هذا العنصر‎ 
: بعنصر محدد البيانات دي إس تأمل الترميز التالي‎ 
da.Fill(ds); 


da->Fill(ds); 
كلمة فيل ۴111 في الإنكليزية تعني الملء وهذا ما تمه هذا الترميز بالفعل تم ملء محدد البيانات - المعصل بذاكة الحاسوب‎ 
الل ادو شا مقر انات - ا في دال حول البيانات يبقى لدينا المرحلة الأيرة وهي ربط محدد البيانات دي‎ 


إس بظهر البيانات داتا جريد فيو ويتم هذا عن طريق الترميز التالي : 

dataGridView1.DataSource = ds. Tables[0]; 
الآن تعال نظر من قرب إلى هذا الترميز . إن مصدر البيانات الحالي بالنسبة لمظهر البيانات هو محدد البيانات إذا‎ 
٥44 $0uإ٥e استسلخنا من مظهر البيانات - وهو عنصر من فئة - خصيصة مصدر البيانات الموسوم بالداتا سورس‎ 
والذني سويناه محدد البيانات للجدول رة صفر . وكا تعام أن العد في معظم العمليات الحوسبية يبدا من الصفر ونظرا لأن‎ 
قاعدة البيانات لا تحوي إلى جدول واحد فكان هو الجدول الأول الذي يحمل وَمة ا مؤشر صفر با لمل سيكون الترميز في لغة‎ 
السي بلس بلس مع بعض التغييرات الطفيفة التي لا تستدعي التعليق تعال الآن فستعرض ترميز زر الإظها ركاملا في لغة‎ 
: اسي شارب تأمل ما يلي‎ 


private void button2 Click(object sender, EventArgs e) 


{ 
SqlConnection sc = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User 
Instance=True"); 
SqIDataAdapter da = new SqlDataAdapter(; 
DataSet ds = new DataSet); 
da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc); 
da.Fill(ds); 
dataGridView1.DataSource = ds. Tables[0]; 


وکا هٽ آنقا أعدنا تعريف نقطة الوصل سي س وكذلك حول البيانات لأنه في الشرح لابد أن پنفرد کل زر بترمیزاته 
الحاصة إذا لا بحسن إظهار الترميز كاملا لقلة النفع في ذلك إلا عند إتهاء الترميز للبرنامج كاملا أما ما سوى ذلك فخداج 
private: System::Void button2 Click(System::Object sender, System::EventArgs? e) {‏ 

SqlConnection? sc = gcnew SqlConnection("Data Source=.\SQLEXPRESS;AttachDbFilename= 

C:\Users\Hassan\Desktop\RandomProject\\hamza.mdf;Integrated Security=True; User 
Instance=True"); 

SqlDataAdapter^ da = gcnew SqlDataAdapterO; 

DataSet? ds = gcnew DataSet); 

da->SelectCommand = gcnew SqlCommand("SELECT * FROM MyTable",sc); 

da->Fill(ds); 

dataGridView1l->DataSource = ds->Tables[0]; 


الآن تعال ننتقل إلى عملية الاختبار للترميز ولكن قبل البدء في ذلك تعال نظر مرة أخرى بدقة في الترميز السابق ستلحظ 
أنه لا يوجد أوامر لتفريغ حدد البيانات وبالتالي كلا ردت آن تضيف “جلا جديدا في قاعدة البيانات خاصتك سيظهر لك 
لقم القديية مضافة إلى القم الجديدة تعال نأخذ هذا التنظير في حيز العطبيق تأمل الحطوات التالية في عملية تحديث 
وإضافة عناصر جديدة داخل قاعدة البيانات . 

الشكل التالي يعبر عن عملية إضافة لمستخدم جديد اسمه علي وكلمة المرور هي خالد عند الإضافة لن يظهر السجل الجديد 
في مظهر البيانات مع أن هذا السجل سيضاف في الحال في قاعدة البيانات الرئيسية ولكنه لن يظهر في مظهر البيانات إلا 


إذا تم الكبس على زر الإظهار الي وضعناه في القالب راجع التصمم الأخير .وهذه مشكلة لا ينبغي القلق بشأًما سفكلم 
عن كيفية حلها فيا بعد بإذن الله تعالى إلا أن الني يعنينا هنا هو المشكلة الحالية ممشكلة التفريغ تأمل عند إضافة مستخدم 
جديد والضغط على زر الإظهار بشرط تعمم التغيرات يعني أن متغير حول البيانات ومتغير الاتصال معمم ومتغير محدد 
البيانات معمم تأمل الترميز التالي : 


public partial class Form1 : Form 


SqlConnection sce = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User Instance=True"); 
SqlDataAdapter da = new SqlDataAdapter(O; 
DataSet ds = new DataSet); 
public Form10) 
InitializeComponent(); 


} 


private void Form1 Load(object sender, EventArgs e) 


{ 
1 


private void button1 Click(object sender, EventArgs e) 


{ 


da.InsertCommand = new SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da.InsertCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1.Text; 
da.InsertCommand.Parameters.Add("@Password", SqlDb Type. VarChar). Value = textBox2. Text; 
sc.Open(); 
da.InsertCommand.ExecuteNonQuery(Û; 
sc.Close(); 

1 


private void button2 Click(object sender, EventArgs e) 


{ 


da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc); 
da.Fill(ds); 
dataGridView1.DataSource = ds. Tables[0]; 


الآن تعال ننظر إلى شكل التطبيق عند إضافة المستخدم علي  :‏ ي 
لاحظ ههنا أنه تم إظهار أحمد كاسم مستخدم و عاطف ككلمة = 
مرور ثلاثة مرات عند كل مرة يتم الضغط فيها على زر الإظهار Far‏ 


ahmad atef 


يتم إظهار نفس القم القدية وهذا كا قلت يحدث فقط في حال nad arf‏ : 


A Khalid 


تعميم المتغيرات والتي من المفترض أن تكون عليه عند إقام الترميز 
ولحل هذه الممكلة سنستخدم أمر التغفريغ لدد البيانات تأمل 
الترميز الاي E‏ 


في لغة السي شارب سيتم إضافة هذا الترميز قبل علية ملء محدد البيانات من محول البيانات وذلك بهذا الترميز : 
da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc);‏ 

ds.Clear(; 

da.Fill(ds); 

dataGridView1.DataSource = ds. Tables[0]; 


السطر العاني في الترميز السابق هو الإضافة والبقية هو ما سبق الكلام عليه غاية الأمر تفريغ محدد البيانات من القم القدية 
والبدء في ملؤه من جديد من حول البيانات وعليه فسيكون الترميز في لغة السي بلس بلس كا يلي : 


namespace Graphics! { 


using namespace System; 

using namespace System::ComponentModel; 
using namespace System::Collections; 

using namespace System::Windows::Forms; 
using namespace System::Data; 

using namespace System::Drawing; 

using namespace System::Data::SqIClient; 


public ref class Form] : public System::Windows::Forms::Form 


{ 
static SqlConnection^ sc = gcnew SqlConnection("Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True;User Instance=True"); 
static SqlDataAdapter^ da = gcnew SqlDataAdapterO); 
static DataSet? ds = gcnew DataSet); 

public: 
Form1(void) 
{ 


InitializeComponentO; 


} 


private: System::Void button1 Click(System::Object sender, System::EventArgs? e) { 
da->InsertCommand = gcnew SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da->InsertCommand->Parameters-> Add("@Username", SqlDbType::VarChar)->Value = textBox1->Text; 
da->InsertCommand->Parameters-> Add("@Password", SqIDbType::VarChar)-> Value = textBox2->Text; 
sc->OpenÛ; 
da->InsertCommand->ExecuteNonQuery(Û; 
sc->Close(); 


private: System::Void button2 Click(System::Object sender, System::EventArgs? e) { 
da->SelectCommand = gcnew SqlCommand("SELECT * FROM MyTable",sc); 
da->Fill(ds); 
dataGridView1->DataSource = ds->Tables[0]; 


لاحظ أننا عندما عممنا المتغيرات الثلاث جعلناها جيعا ثابتة 512٤1٥‏ تبما لنظام جمع الترميزات الحخاص بالسي بلس بلس و 
تعمدت آن أضع قاطا بين الترميزات لأشير إلى أن هناك نقص تعمدته للاختصار إذ لا خفى على قرسي هذه اللغة أن 
ترميزات التصميم تكون مدمجة مع ترميزات الدوال والوظائف و على هذا الحال تكون مسالة تحديث البيانات في الجدول 
الاقتراضي المسمى بظهر البيانات قد تمت بفضل الله وحده . فإذا وعيت ما سبق فاعلم - وفقك الله تعالى - أنه يازمك 
معرفة كيفية التدقل بين البيانات ذهابا وإيابا والقفز إلى آخر بيانية غ العودة إلى أولها وهذه من أيسر المسائل لأا لن 
تتطلب منك كبير جمد أفيدك بالعلم فيا ههنا فأقول مستيعنا بالله تعالى : نبد أولا بالتصميم سنضع أربعة أزرار جدد في 
واجمة المستخدم الخاصة بنا فسيكون الشكل الهائي كا يلي : 

هنا بإضافة زر ليقفز بمؤشر الاختيار إلى آخر جل 
وزر آخر للقفز إلى أول السجلات وواحد للسجل 
الاي وآخر للسجل السابق هذه الأزرار زود ف 
وظائنها على فئة تسمى ملازمة المصدر - بكسر 
الزاي وفتح الي هذه الفئة تقوم بملازمة عنصر 
الاختيار في المصدر بحيث حيها تمت عملية التتقل 
بین “جل وآخر فانه یتم تغییر حتوی صندوق النص 
إلى السجل المشار إليه ف قاعدة البيانات وهكذا 


تؤثر في عملية عرض البيانات سواء من خلال مظهر | [amar _) [Add‏ 
البيانات أوشن خلال صنادیق النصوص آو ما Est)‏ | 


سواها على حسب التطبيق المراد تنفيذه . 
وعليه فباديء ذي بدء تعال ننظر في تعريف فئة ملازمة المصدر أما ف الي شارب فسیکون الوضع هکذا : 
BindingSource bs = new BindingSource);‏ 

وأما في السي بلس بلس فسيتم إضافة هذا الرميز بشكل يمعي في الشكل الهائي في تقس الح الذي عرفنا فيه عناصر 
فئات موصل الإس كيو إل ومحول البيانات وكذلك محدد البيانات فهذه رابعتا على الشكل التالي : 

static BindingSource? bs = gcnew BindingSource(); 
الآن ياي دور استخدام عنصر هذه الفئة مع أدوات الإظهار الختلفة للبيانات إذ لكي يؤتي هذا العنصر مارا فإنه لابد وأن‎ 
يتصل بمصدر ما للبيانات وكا فعلنا عندما استخدمنا خصيصة تلقي المصدر في مظهر البيانات الموسوم داتا جريد فيو فإن‎ 
فکان من‎ 04145٥۲ عنصر فئة ملازمة المصدر بجوي نقس الخصيصة ولا كان المصدر مسجلا ف محدد البیانات داتا سیت‎ 
. شأن هذا العنصر إذا أن يسير على نفس المنوال‎ 
وقد يقول قائل : وما الفائدة الفعلية من ربط عنصر ملازم المصدر محدد البيانات ؟‎ 
فا جواب : أن ام يدل على المسمى إن ملازم المصدر لابد له أن يكون مرتبطا ملازمة لمصدر ما من مصادر البيانات لكي‎ 


يمكن استخدامه كحلقة وصل التأثير على كل ما يتصل بعنصر ملازم ا مصدر تعال نظ ر كيف نكب هنا الرميز باللفتين : 
أما في السي شارب فسيكون الوضم كا يلي : 
bs.DataSource = ds. Tables[0];‏ 


هذه خصيصة استسلخناها من عنصر فئة ملازمة المصدر المسمى بي إس جعلت حلقة الوصل بين هذا العنصر وبين 
الجدول الأول المرتبط محدد البيانات وقد تكلمنا في مسألة سالفة عن ارم صفر الموضوع وإلام يشير فلا حاجة للإعادة 
ههنا . 
في لغة السي بلس بلس سيكون ترميز هذا الأمر على التحو التالي : 

bs->DataSource = ds->Tables[0]; 


وضعنا هذا الترميز في دالة زر الإظهار رهامءنط لكي يتم تحديث مصدر عنصر الفئة الملازمة للمصد ركلا تم تحديث 
محتويات محدد البيانات الموسوم بدي إس والني يتم تفريغه من القيم القدية كلها ضغط - بضم الضاد وكسر الغين - على 
تقس الزر يعني زر الإظهار . 

فإذا تبين لك ذلك فاعلم - رحمك الله - أننا سنقوم بنفس العملية الإلزامية ولكها معكوسة يعني ننا في الترميز السابق 
ألزمنا عنصر ملازمة النص بعنصر مدد البيانات ولكن في هذه المرحلة سنلزم صندوق النصوص بعنصر ملازمة النص فيا 
يتغير عنصر ملازمة النص تبعا لتغير محدد البيانات فإنه سيتم حدوث نفس التغبير في صناديق النصوص تأمل الترميز العالي 
لغة الي شارب : 


textBox1.DataBindings.Add(new Binding(" Text", bs, "Username")); 
textBox2.DataBindings.Add(new Binding("Text", bs, "Password")); 


هذا الترميز سيوضع أيضا في نفس دالة زر الإظهار تعال ننظر في هذا الترميز عن كفب ستجد ننا ألزمنا صندوق النص 
الأول بنوع معين من البيانات هذه البيانات هي نصوص وهذا معنى كلمة ٦۴×‏ ا لمكتوبة في بداية التعريف وهذه البيانات 
أيضا مأخوذة من عنصر فئة ملازمة النص المسمى بي إس وحيث أن عنصر ملازمة النص يحوي نوعين من البيانات أحدها 
متعلق باسم المستخدم والآخر متعلق بكلمة المرور فاخترنا لصندوق النص الأول أن يحمل قي امم المستخدم واخترنا 
لصندوق النص الثاني أن يحمل قي كلمة المرور . إذا فهذا الترميز يعبر عن كل التفاصيل وا لخصائص المطلوبة اربط وحدة 
تح معينة في واحمة الاستخدام كصناديق النصوص وما شابمها . 

الآن يفترض أن يكون ترميز زر الإظهار في السي شارب على النحو التالي : 


private void button2 Click(object sender, EventArgs e) 


da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc); 
ds.Clear(); 

da.Fill(ds); 

dataGridView1.DataSource = ds. Tables[0]; 

bs.DataSource = ds.Tables[0]; 

textBox1.DataBindings.Add(new Binding("Text", bs, "Username")); 
textBox2.DataBindings.Add(new Binding("Text", bs, "Password")); 


} 
هذا طبعا مع عدم إغفال أننا عرفنا عنصر فئة ملازمة النص بي إس في أعلى الترميز لكي يكون عمومي الاستخدام في جيع 


الطرق الموجودة في الترميز بالمثل في السي بلس بلس سيكون الترميز الاص بنفس الزر على الشكل التالي : 

private: System:: Void button2 Click(System::Object sender, System::EventArgs? e) { 

da->SelectCommand = gcnew SqlCommand("SELECT * FROM MyTable",sc); 

ds->Clear(); 

da->Fill(ds); 

dataGridView1->DataSource = ds->Tables[0]; 

bs->DataSource = ds->Tables[0]; 

textBox1->DataBindings-> Add(gcnew Binding("Text",bs,"Username")); 

textBox2- ف‎ >Add(gcenew Binding("Text",bs, "Password")); 


تعال ننظر مالعغيير الذي أحدثه هذا الترميز حى الآن . عند تشغيل البرنا TEES‏ 
حسب المكان المشار إليه في مظهر البيانات أو الجدول الافتراضي تأمل الک التالي : 

کا تلاحظ ستجد أن صندوق النص قد امتلاً بالقم لار و : 
الجدول الاقتراضي أو مظهر البيانات وکنا لازلنا لا نستطيع أن 
نفير ما بداخل صندوق النص إذا ما أشرنا بزر الفأرة عند أية 
جلات آخرى مما يعني أا سنحتاج إلى تفعيل أزرار التصفح 
يعني تصفح السجلات وهي الأربعة الأزرار التي أضفناها في بداية 
الكلام في هذه المسالة لكي قعل هذه الأزرار سنقوم فقط 
باستخدام طرق ضمنية في عنصر فئة ملازمة المصدر بي إس أو 
ييندينج سورس تكنك من التصفح ذهابا وإيابا تعال نجرب وضع 
ترميز التصفح في السجل التالي عن الزر نیکست ۸×۲ سيكون 
الترميز فيه على النحو التالي في لغة الي شارب : 


private void button4 Click(object sender, EventArgs e) 


bs.MoveNext(0; 


} 
عند تشغيل البرنامج ستلحظ أن صناديق النصوص تتغير مها كلا ضغطت على زر التالي ولكن المؤشر في مُظور البيانات 
لا يتغير . فهذا يعني أن عملية التحديث غير جارية لمظهر البيانات فاستلزم ذلك إضافة ترميز بربط بين عملية تحديث مظهر 
البيانات وبين زر التصفح وعليه يكننا إضافة الترميز التالي : 


dataGridView1.ClearSelection)O; 
dataGridView1.Rows[bs.Position].Selected = true; 


آما عن السطر الأول فقي رفع التحديد عن أي عنصر من عناصر ال جدول الاقتراضي أو مظهر البيانات فهذا لا إشكال فيه 
أما السطر الثاني فني تحديد الصف ۸٠١7‏ في مظهر البيانات للموقع الذي فيه ملازم المصدر وحيث أا قمة بوليانية أو 
ؤو ية ا ما إذاکان م ملا ختارا فقد أعطيت ا " صدق True"‏ . 


ملازم المصدر بي إس عندما يكون عند السجل أحمد و خالد مثلا فهذا سينعكس على الصف المابل له في مظهر البيانات 
أو الجدول الافتراضي وهكذا . 

وما لا شك فيه أنه بدلا من تنفيذ نفس السطرين عند كل زي تقل أو تصفح بين المستخدمين المسجلين في قاعدة البيانات 
مكننا أن ننشيء طريقة تحوي هذين السطرين ثم ننسخ رأس هذه الطريقة عند كل زر تنقل من شأن هذا آن يكون 
احترافية في الترميز وعليه سيكون الترميز النهائي للأزرار على المشكل التالي في السي شارب : 


private void button4 Click(object sender, EventArgs e) 


bs.MoveNext(0; 
Update); 


} 


private void button3 Click(object sender, EventArgs e) 


bs.MoveFirst(; 
Update); 


private void buttonS Click(object sender, EventArgs e) 


bs.MovePrevious(); 
Update); 


private void button6_ Click(object sender, EventArgs e) 


bs.MoveLast(; 
Update); 


private void Update) 


dataGridView1.ClearSelection(); 
dataGridView1.Rows[bs.Position].Selected = true; 


: في لغة السي بلس بلس سيكون الوضع كما يلي‎ 
private: System:: Void button4 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveNext(; 
Update); 
} 


private: System::Void button3 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveFirstO; 
Update); 


private: System::Void buttonS Click(System::Object sender, System::EventArgs? e) { 
bs->MovePrevious(); 
Update); 


private: System:: Void button6 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveLast(); 
Update); 


private: void Update) 
{ 


dataGridView1->ClearSelection(); 
dataGridView1->Rows[bs->Position]->Selected = true; 


أن غند اعجار ارامح من دن غير أك علامة عند هين اجام وكة اأرور الشاهردن في ترق الت ا 
نهاية لمسألة أخرى وعليه فإن تبين لك الحق فما سبق فإليك مسألة جديدة في تحديث البيانات المدحلة مسبقا ولنبدا فها 
کا نبد في كل مسألة بالتصميم فقط سنضيف زرا جديدا ولنسمه تعديل أو تحديث ترسم إنكليزيا هكذا رگله تأمل 
الشكل العام المقابل : 

لكي نطبق علية تعديل “جل تم تسجيله مسبقا في قاعدة 
بيانات إس كو إل سنقوم باستخدام تقس عنصر محول 
البیانات داتا آدابتر ۲م1444( وکن هذه المرة مع 
أمر التحديث . إنك إذا راجعت المسائل السابقة ستلحظ 
ننا قد استسلخنا من هذا العنصر بعض الخصائص التي 
كانت تساعدةا على التعامل مع نوع الأوامر المراد توجيهها إلى 
قاعدة البيانات فكا سبق التنبيه عليه فإن حول البيانات 
هو المغاوض بين عناصر الح ف قالب النوافذ وبين قاعدة aa‏ 
اينات الإس كيو إل ويه فلكي قوم يله اللي ا[ م ي 
سام إل رط هاا امي مرن ا ی 
صندوتي النص اللذين سيعرضان المعلومات التي تعبر عن السطر الذي يتف عنده الاختيار في الجدول الفرعي وفي حين 
تغيير هذه القيم والضغط على زر التعديل سيتم حفظ التعديل محل السجل الذي سبق عليه الاختيار أو المعلم باللون 
الأزرق كا في التطبيق أعلاه تعال ننظر في التطبيق . 

الطب سنقوم بالضغط مرتين على الزر ال جديد وضع الرميزات التي سينفذها هذا الزر سيكون النسيز كا يلي : 


da.UpdateCommand = new SqlCommand("UPDATE MyTable SET Username =@Username,Password = 
(@Password WHERE ID =@ID", sc); 


لاحظ ههنا هذا الترميز بعد باستدعاء عنصر محول البيانات ثم استخرج منه خصيصة فرعية هي أمر التحديث علقت 
بعنصر جديد ئة أوامر الإس كيو إل داخل القوس يكتب ترميز الإس كيو إل وااني مفاده عملية تحديث للجدول المسعى 
ماي تايبل .كلمة 55 تعني عين وة كذا في كذا وههنا تعني تعيين قمة اسم المستخدم المعرف في قاعدة البيانات داخل 
متغیر جدید امه آت یوزرنامم Username‏ @ وبا مئل في حال كلمة المرور حيث يتطابق رغ الهوية آي دي مع متغير 
خاص به هكذا تم تعيين قم متغيرات معينة تتعلق بسجل معين ذا رم هوية معينة في قاعدة البيانات الأساسية . 

الترميز في لغة السي بلس بلس سيكون كالآتي : 


da->UpdateCommand = gcnew SqlCommand("UPDATE MyTable SET Username =@Username,Password = 


@Password WHERE ID =@ID", sc); 

من الحسن أن تقوم ببناء مشروعك كلا أحدثت تغييرا لكي تدرك أين موطن الخطا إذ لو بدأت في الترميز منذ البداية إلى 

الهاية بدون بناء للمشروع أو اختبار لن تدري أين وقع الخطأ يعني ستكون مساحة البحث عن الخطا أكبر وإليك ههنا 
شكلا يبن لك كيفية العمل عند وضع كل جزء جديد في الترميز أو التصميم تأمل دورة حياة العملية البرجية فها يلي : 


سال حصاتل ال 
تل 2 تصدىق يتجاح اکر للارھاء ہا 


رالتسظرات والخرارميات 


طسق الأقكار والأطروحات 


تبح ج الأحطاء أو قصددق 
تجاح العملية 
CC‏ 


نعود إلى المسألة ههنا يعني مسألة تحديث البيانات فأقول مسخعينا بالله تعالى : بعد إضافة هذا الأمر رجي لمغاوضة قاعدة 
البيانات بلغة الإس كيو إل لقنم عملية التحديث في الجدول أو القامة المشار إلها ثم بعد ذلك قعل كا فعلنا بالضبط في 
عمليات الإضافة ولأن عملية التعديل هي في حقيقنما عملية إضافة لقاعدة البيانات مع بعض الفروض عن عليات الإضافة 
الصرفة إلا أن الترميز لن يختلف كغرا إلافي نوع الأمر ففي مسألة إضافة جل لقاعدة البيانات كا بكب الأوامر 
المستسلخة من حول البيانات الدي إيه للإضافة 1١٥۲٤٥٥1٣2٩‏ لكا ههنا ندخل ٥0۳ ٣21‏ )هلما تأمل 
الترميزات التالية : 

O TT MT MTT 


da.UpdateCommand.Parameters. Add((@Password", SqlDb Type. VarChar). Value = textBox2. Text; 
da.UpdateCommand.Parameters. Add("@ID", SqlDbType.Int). Value = ds. Tables[0].Rows[bs.Position][0]; 


أما الترميزين الأولين فلا حاجة لنا في التفصيل فيا بل نوجز فيا القول أا عبارة عن عملية ملء للمتغيرات البياناتية بالقم 
المراد تعديلها من خلال صندوق النص الأول والعاني کا هو ظاهر . 
وأما الترميز اثالث ففيه تفصيل . هذا الترميز يتعلق بعملية تحديد سطر بعينه لكي يتم التعديل فيه إذ لو لم يتم تحديد مؤشر 


السطر المراد تحديثه فإنه سيتم تغيي ركل الاسماء وكلهات المرور في قاعدة البيانات إلى القم الجديدة الماخلة عن طريق 
صندوقي النص ولذلك کان لاپد من تحدید السطر عن طریق 3 الهوية الآي دي من أجل أن û‏ التحديث أو التعديل 
عند هذا السطر فقط بعينه دون غيره فنقول بأن القسم الأول من الترميز الأخير عبارة عن عملية إضافة لمتغير بياناتي امه 
آي دي تم تحديد نوع الق المدخلة إليه وهي العدد الصحيح إجر - بتعطیش الج - ٥۲‏ ع٥۲٦1‏ ثم يتم تحويل ما بداخل 
القوس إلى وة مستوعبة تقبل التساوي مع الطرف الآخر من المعاداة . 
عند الطرف الآخر أشرةا إلى الجدول الول ذو الؤشر صف ركا تكلمنا عليه وهو الجدول الوحيد المسمى ماي تايل 
استخلصناه من البيانات المسجاة فعليا في حدد البيانات دي إس عند موضع الصف الذي عنده عنصر فئة ملازمة المصدر 
لأنه من البديهي أن هذا المنصر لن يتوقف ويظهر ما هو عليه في صندوتي النص إلا إذاكان عند السطر الراد تعديله وأما 
الصفر الأخير فيرمز إلى رغ العامود ومعلوم أن العامود الذي فيه الهوية هو أول عامود والعد يبدا من الرغم صفر کا ينا سابقا 
فهذا بيان هذا الترميز . 
إذا تبين لك ذلك تعال ندر في بقية الترميز سنحتاج إذا كا فعلنا من قبل في مسألة إضافة العناصر إلى فتح الاتصال 
قاعدة بيانات الإس كيو إل ثم إظهار الأوامر المراد تنفيذها وهي التحديث أو التعديل ههنا م ضلق الاتصال وعلية 
الاتصال هذه لن تتم إلا عن طريق عنصر فتة اتصال الإس كو إل والني أمميناه مسبقا إس سي والني يحمل الامعداد 
الكامل للموقع الفعلي لقاعدة البيانات راجع المسألة الأولى في هذا الشأن ثم تفقد الترميز التالي : 

sc.OpenO; 


da.UpdateCommand.ExecuteNonQueryÛ; 
sc.Close); 


عند فتح تصال سیم قذف ما يحويه حول البيانات من المدخلات القادمة من واحمة المستخدم إلى داخل القاعدة 
البياناتية الأساسية ثم يتم غلق الاتصال بعد ذلك . في لغة الي بلس بلس سيكون الترميزكالآتي : 


private: System::Void button7_ Click(System::Object sender, System::EventArgs? e) { 


da->UpdateCommand = gcnew SqlCommand("UPDATE MyTable SET Username =@Username,Password = 
@Password WHERE ID =@ID'"', sc); 
da->UpdateCommand->Parameters->Add("@Username",SqlDbType::VarChar)->Value = textBox1->Text; 
da->UpdateCommand->Parameters->Add('"@Password",SqlDbType::VarChar)->Value = textBox2->Text; 
da->UpdateCommand->Parameters->Add("@ID",SqlDbType::Int)-> Value = ds->Tables[0]->Rows[bs->Position][0]; 


sc->OpenÛ; 
da->UpdateCommand->ExecuteNonQuery(Û; 
sc->Close); 


: بالمعل في لغة السي شارب سيكون الترميز كا يلي‎ 
private void button7_ Click(object sender, EventArgs e) 
{ 
da.UpdateCommand = new SqlCommand("UPDATE MyTable SET Username =@Username,Password = @Password 
WHERE ID =@ID", sc); 
da.UpdateCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1. Text; 
da.UpdateCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1. Text; 
da.UpdateCommand.Parameters.Add("@ID", SqlDbType.Int). Value = ds.Tables[0].Rows[bs.Position][0]; 
sc.Open(Û); 
da.UpdateCommand.ExecuteNonQueryÛ; 


sc.Close(); 
عند تنفيذ صلية تعديل ما عن طريق صندوق التص اضغط على زر التمديل في اضغط مل آبا من آزرار التعدیث دول‎ 
اينات الفرمي ستجد أن التعديث قد تم بامعل في غر عملية الععديث كممليات الإضافة وبكنك أيضا أن تجعل علبة‎ 
ديت البينات ضمنية عن طرق تنفيذ س ترميز رر الإظهار الني تكلمنا يه في بداية هنا البحث بإضافة الارمير‎ 
التالي داخل دالة زي التحدیث أو زي الإضافة و کلاها وه وکا يلي:‎ 
button2.PerformClickO; 


ستحتاج أيضا لی أن تضع عہلية التلازم بين أمري التجرب به والإمساك المساة إنکليزياتراي کاتش Try Catch‏ سیک 
ذلك على النحو التالي في زر التحديث كا يلي : 
private void button2 Click(object sender, EventArgs e)‏ 
da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc);‏ 
ds.Clear();‏ 
da.Fill(ds);‏ 
dataGridView1.DataSource = ds. Tables[0];‏ 
bs.DataSource = ds.Tables[0];‏ 
try‏ 
{ 
textBox1.DataBindings. Add(new Binding(" Text", bs, "Username"));‏ 
textBox2.DataBindings.Add(new Binding("Text", bs, "Password"));‏ 


catch (Exception) 


هذا التمديل سيجعل عملية تحديث البيانات علية مظية أن تمتاج أن تضغط على أكثر من زر التحديث لترى الشكل 
الجديد للبيانات ويمكن استخدام نفس الطريقة في عملية الإضافة أو في المسالة التالية وهي مسالة في إزالة السجلات من 
قاعدة البيانات فاع - رحمك الله تعالى - أن الإزالة والإضافة والتحديث في قواعد البیانات كلها تشتبه في جل ترمیزا مما 
E‏ ا في کل الشكل 
العام لواحمة المستخدم للبرنامج وهي کا يلي : 

کا ترى في الشكل المقابل شنا بإضافة زر جديد في القالب أسميناه 
إزالة أو ديليت وکا قلٽت من قبل أمر الإزالة يتشابه 
اما مع الأوامر التي سبق الكلام علا فيا يتعلق بقواعد البيانات 
وعليه فسنقوم باستسلاخ من حول البيانات أمر الإزالة مع إرفاق 
کل ترمیز مع ما یقابله من أرقام مؤشرا ات الصف أو الانة : 


ه لغة | شا | هکزا : | [Delete | (modify | (Display | Add‏ 
في لغة السي شارب سيكون الوضع Ct )(remn ) CEET CR J]‏ 


da.DeleteCommand = new SqlCommand("Delete FROM MyTable 
WHERE ID = @ID", sc); 


da.DeleteCommand.Parameters.Add("@ID", SqlDbType.Int). Value = ds.Tables[0].Rows[bs.Position][0]; 


sc.Open(); 
da.DeleteCommand.ExecuteNonQuery(); 
sc.Close(); 


ds.Clear(); 
da.Fill(ds); 


تعال نراجع هذا الترميز في تجالة . أخذنا خصيصة فرعية تقبل إدخال أمر إس كيو إل لإزالة صف معين من الصفوف وجعلنا 
علامة الإزالة هي الهوية يعني هوية الصف ولا يكن أن تكون سوى ذلك فاسم المستخدم قد يتشابه كا يكن أن تتشابه 
كلمات المرور لكن الني ييز صف بياناتي عن صف خر هو رم الهوية التابع لكل صف وبالتالي إذا أزيل الصف الحدد برق 
هوية معينة فإن هذا لن يكلفك فقدانا لأكثر من ذلك من البيانات ولو تشابت البيانات التي يراد إزالتها مع أخرى لا يراد 
التخاص منا . أما عن السطر العاني فشبيه بالسطر الذي ورد في ترميز عملية التحديث ومفاده تحديد الصف الذي عنده 
يقف عنصر فئة ملازمة المصدر وحيث أن العامود الأول هو عامود الهوية آي دي فلابد وأن يكون ومة مؤشره تساوي 
الصفر وهذا معنى الصفر الأخير في آخر الترميز . 

ثم بعد ذلك تبعت هذه الأوامر عملية فتح للاتصال ثم قذف الأوامر الجديدة التي يحويها محول البيانات داخل قاعدة البيانات 
الريسية م قفل الانصال بقاعدة البيانات من جدید ينیع ذلك تريغ حدد البیانات من التم القدية م ملؤه من القم الجديدة 
التي يحويا حول البيانات دي إيه وهذه المسألة أيضا قد أوضصناها آنقا ا يغني عن الإعادة هنا فليعلم ! 

ترميز لغة السي بلس بلس من شأنه أن يكون كا يلي : 

private: System::Void button8_ Click(System::Object? sender, System::EventArgs^ e) { 


da->DeleteCommand = gcnew SqlCommand("Delete FROM MyTable WHERE ID = @ID", sc); 
da->DeleteCommand->Parameters->Add("@ID", SqIDbTYype::Int)-> Value = ds->Tables[0]->Rows[bs->Position][0]; 


sc->Open(Û; 
da->DeleteCommand->ExecuteNonQueryÛ; 
sc->Close(); 


ds->Clear(0; 
da->Fill(ds); 


1 
الآن وقد تمت المسائل الراد إدراجما في رسالتي الختصرة هذه تعال نستعرض الترميز الكامل لكلا من السي شارب والسي 
بلس باس بدا بالمی شارب سیکون ترمیز البرفامج پپاکیا بل : 


using System; 

using System.Collections.Generic; 
using System.ComponentModel; 
using System.Data; 

using System.Drawing; 

using System.Linq; 

using System. Text; 

using System. Windows.Forms; 
using System.Data.SqIClient; 


namespace RandomProject 


public partial class Form1 : Form 


SqlConnection sc = new SqlConnection(@"Data Source=.\SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True; User Instance=True"); 

SqlDataAdapter da = new SqlDataAdapter(; 

DataSet ds = new DataSet(; 

BindingSource bs = new BindingSource(); 


public Form10) 


InitializeComponentO; 


} 


private void Form1 Load(object sender, EventArgs e) 


{ 
} 


private void button1 Click(object sender, EventArgs e) 


{ 


da.InsertCommand = new SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da.InsertCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1.Text; 
da.InsertCommand.Parameters.Add("@Password", SqlDb Type. VarChar). Value = textBox2. Text; 

sc.Open(); 

da.InsertCommand.ExecuteNonQuery(Û; 

sc.Close(); 


private void button2 Click(object sender, EventArgs e) 


{ 


da.SelectCommand = new SqlCommand("SELECT * FROM MyTable",sc); 
ds.Clear(); 

da.Fill(ds); 

dataGridView1.DataSource = ds.Tables[0]; 

bs.DataSource = ds.Tables[0]; 


try 


textBox1.DataBindings.Add(new Binding(" Text", bs, "Username")); 
textBox2.DataBindings.Add(new Binding("Text", bs, "Password")); 


catch (Exception) 


{} 


private void button4 Click(object sender, EventArgs e) 


bs.MoveNext(0; 
Update); 


} 


private void button3 Click(object sender, EventArgs e) 


bs.MoveFirst(; 
Update); 


private void buttonS Click(object sender, EventArgs e) 


bs.MovePrevious(); 
Update); 


private void button6 Click(object sender, EventArgs e) 


bs.MoveLast(); 
Update); 


private void Update) 


dataGridView1.ClearSelection(); 
dataGridView1.Rows[bs.Position].Selected = true; 


} 


private void button7_ Click(object sender, EventArgs e) 
{ 
da.UpdateCommand = new SqlCommand("UPDATE MyTable SET Username =@Username,Password = (@Password 
WHERE ID =@ID"', sc); 
da.UpdateCommand.Parameters.Add("@Username", SqlDb Type. VarChar). Value = textBox1. Text; 
da.UpdateCommand.Parameters.Add("@Password", SqlDbType. VarChar). Value = textBox2. Text; 
da.UpdateCommand.Parameters.Add("@ID", SqlDbType.Int). Value = ds.Tables[0].Rows[bs.Position][0]; 


sc.Open(); 
da.UpdateCommand.ExecuteNonQueryÛ; 
sc.Close(); 

button2.PerformClick(0; 


ی 
private void button Click(object sender, EventArgs e)‏ 
da.DeleteCommand = new SqlCommand("Delete FROM MyTable WHERE ID = @ID", sc);‏ 
da.DeleteCommand.Parameters.Add("@ID", SqlDbType.Int). Value =‏ 
ds.Tables[0].Rows[bs.Position][0];‏ 
sc.OpenÛO;‏ 


da.DeleteCommand.ExecuteNonQuery(); 
sc.Close(); 


ds.Clear(); 
da.Fill(ds); 


أما عن ترميز السي بلس بلس فسيكون كالاتي : 


#pragma once 


namespace Graphics1 { 


using namespace System; 

using namespace System::ComponentModel; 
using namespace System::Collections; 

using namespace System:: Windows::Forms; 
using namespace System::Data; 

using namespace System::Drawing; 

using namespace System::Data::SqlClient; 


public ref class Form] : public System::Windows::Forms::Form 


{ 


static SqlConnection? sc = gcnew SqlConnection("Data Source=. \SQLEXPRESS;AttachDbFilename= 
C:\Users\Hassan\Desktop\RandomProject\hamza.mdf;Integrated Security=True;User Instance=True"); 
static SqlDataAdapter^ da = gcnew SqlDataAdapterO); 
static DataSet? ds = gcnew DataSet); 
private: System::Windows::Forms::Button? button7; 
private: System::Windows::Forms::Button? button8; 
static BindingSource? bs = gcnew BindingSource(); 


public: 
Form! (void) 
{ 
InitializeComponent(; 
// 
//TODO: Add the constructor code here 
// 


} 


protected: 
/// <summary> 
/// Clean up any resources being used. 
/// <Isummary> 
~Form10 


if (components) 


delete components; 


} 
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private: System::Windows::Forms::TextBox^ textBox1; 

protected: 

private: System::Windows::Forms::TextBox^ textBox2; 

private: System::Windows::Forms::Button? buttonl; 

private: System::Windows::Forms::DataGrid View? dataGridViewl; 
private: System::Windows::Forms::Button? button2; 

private: System::Windows::Forms::Button? button3; 

private: System::Windows::Forms::Button^ button4; 

private: System::Windows::Forms::Button^ button5; 

private: System::Windows::Forms::Button? button6; 


protected: 
private: 


/// <summary> 
/// Required designer variable. 


/// <Isummary> 
System::ComponentModel::Container “components; 


#pragma region Windows Form Designer generated code 

/// <summary> 

/// Required method for Designer support - do not modify 

/// the contents of this method with the code editor. 

/// <Isummary> 

void InitializeComponent(void) 

{ 
this->textBox1 = (gcnew System::Windows::Forms::TextBox(0); 
this->textBox2 = (gcenew System::Windows::Forms::TextBox(0); 
this->button1 = (gcnew System:: Windows::Forms::Button()); 
this->dataGrid View1 = (gcnew System::Windows::Forms::DataGridView()); 
this->button2 = (gcnew System::Windows::Forms::Button()); 
this->button3 = (gcnew System::Windows::Forms::Button()); 
this->button4 = (gcnew System::Windows::Forms::Button()); 
this->buttonS = (gcnew System::Windows::Forms::Button()); 
this->button6 = (gcnew System::Windows::Forms::Button()); 
this->button7 = (gcnew System::Windows::Forms::Button()); 
this->button8 = (gcnew System::Windows::Forms::Button()); 
(cli::safe cast<System::ComponentModel1::I1SupportInitialize? >(this->dataGrid View 1))->BeginInit(); 
this->Suspend Layout); 
// 
// textBox1 
// 
this->textBox1->Location = System::Drawing::Point(93, 23); 
this->textBox1->Name = L"textBox1"; 
this->textBox1->Size = System::Drawing::Size(116, 20); 
this->textBox1->TabIndex = 0; 
// 
// textBox2 
// 
this->textBox2->Location = System::Drawing::Point(215, 23); 
this->textBox2->Name = L"textBox2"; 
this->textBox2->Size = System::Drawing::Size(136, 20); 
this->textBox2->TabIndex = 1; 
// 
// button! 
// 
this->button1->Location = System::Drawing::Point(296, 300); 
this->button1->Name = L"button1"; 
this->button1->Size = System::Drawing::Size(75, 23); 
this->button1->TabIndex = 2; 
this->button1->Text = L"Add'"; 
this->button1->UseVisualStyleBackColor = true; 
this->button1->Click += gcnew System::EventHandler(this, &Form1::buttonl1 Click); 
1 
// dataGridView1 
// 
this->dataGrid View 1->ColumnHeadersHeightSizeMode = 

System::Windows::Forms::DataGridViewColumnHeadersHeightSizeMode::AutoSize; 

this->dataGrid View1-> Location = System::Drawing::Point(12, 60); 
this->dataGridView1->Name = L"dataGridView1"; 
this->dataGrid View 1->Size = System::Drawing::Size(396, 220); 
this->dataGridView1->TabIndex = 3; 
// 
// button2 


/ 

this->button2->Location = System::Drawing::Point(215, 300); 

this->button2->Name = L"button2"; 

this->button2->Size = System::Drawing::Size(75, 23); 

this->button2->TabIndex = 4; 

this->button2->Text = L"Display"; 

this->button2->UseVisualStyleBackColor = true; 

this->button2->Click += gcnew System::EventHandler(this, &Form1::button2 Click); 
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// button3 

// 

this->button3->Location = System::Drawing::Point(296, 329); 

this->button3->Name = L"button3"; 

this->button3->Size = System::Drawing::Size(75, 23); 

this->button3->TabIndex = 5; 

this->button3->Text = L"First"; 

this->button3->UseVisualStyleBackColor = true; 

this->button3->Click += gcnew System::EventHandler(this, &Form1::button3_ Click); 
// 

// button4 

// 

this->button4->Location = System::Drawing::Point(215, 329); 

this->button4->Name = L"button4"; 

this->button4->Size = System::Drawing::Size(75, 23); 

this->button4->TabIndex = 6; 

this->button4->Text = L"Next"; 

this->button4->UseVisualStyleBackColor = true; 

this->button4->Click += gcnew System::EventHandler(this, &Form1::button4 Click); 
// 

// buttonS 

// 

this->buttonS->Location = System::Drawing::Point(134, 329); 

this->button5->Name = L"button5"; 

this->buttonS->Size = System::Drawing::Size(75, 23); 

this->buttonS5->TabIndex = 7; 

this->button5->Text = L"Previous"; 

this->button5->UseVisualStyleBackColor = true; 

this->button5->Click += gcnew System::EventHandler(this, &Form1::buttonS5_ Click); 
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// button6 

// 

this->button6->Location = System::Drawing::Point(53, 329); 

this->button6->Name = L"button6"; 

this->button6->Size = System::Drawing::Size(75, 23); 

this->button6->TabIndex = 8; 

this->button6->Text = L"Last"; 

this->button6->UseVisualStyleBackColor = true; 

this->button6->Click += gcnew System::EventHandler(this, &Form1::button6_ Click); 
// 

// button7 

// 

this->button7->Location = System::Drawing::Point(134, 300); 

this->button7->Name = L"button7"; 

this->button7->Size = System::Drawing::Size(75, 23); 

this->button7->TabIndex = 9; 

this->button7->Text = L"Modify"; 

this->button7->UseVisualStyleBackColor = true; 

this->button7->Click += gcnew System::EventHandler(this, &Form1::button7_ Click); 


/ 

// button8 

/ 

this->button8->Location = System::Drawing::Point(53, 300); 

this->button8->Name = L"button8"; 

this->button8->Size = System::Drawing::Size(75, 23); 

this->button8->TabIndex = 10; 

this->button8->Text = L"Delete"; 

this->button8->UseVisualStyleBackColor = true; 

this->button8->Click += gcnew System::EventHandler(this, &Form1::button8 Click); 


this->AutoScaleDimensions = System::Drawing::SizeF(6, 13); 
this->AutoScaleMode = System::Windows::Forms::AutoScaleMode::Font; 
this->ClientSize = System::Drawing::Size(420, 364); 

this->Controls-> Add(this->button8); 

this->Controls-> Add(this->button7); 

this->Controls-> Add(this->button6); 

this->Controls-> Add(this->button5); 

this->Controls-> Add(this->button4); 

this->Controls->Add(this->button3); 

this->Controls-> Add(this->button2); 

this->Controls-> Add(this->dataGridView1); 

this->Controls-> Add(this->button1); 

this->Controls-> Add(this->textBox2); 

this->Controls-> Add(this->textBox 1); 

this->Name = L"Form1"; 

this->Text = L"Forml]l'"; 

this->Load += gcnew System::EventHandler(this, &Form1::Forml1 Load); 
this->Click += gcnew System::EventHandler(this, &Form1::Form1_ Click); 
(cli::safe_cast<System::ComponentModel!::I1SupportInitialize* >(this->dataGrid View1))->EndInit(; 
this->ResumeLayout(false); 

this->PerformLayoutO; 


} 


#pragma endregion 


private: System:: Void Form1 Load(System::Object? sender, System::EventArgs? e) { 


private: System::Void Form1_ Click(System::Object* sender, System::EventArgs^ e) { 


private: System::Void buttonl1 Click(System::Object* sender, System::EventArgs^ e) { 


da->InsertCommand = gcnew SqlCommand("INSERT INTO MyTable VALUES(@Username,@Password)", sc); 
da->InsertCommand->Parameters-> Add("@Username", SqlDbType::VarChar)->Value = textBox1->Text; 
da->InsertCommand->Parameters-> Add("@Password", SqlDbType::VarChar)-> Value = textBox2->Text; 


sc->OpenÛ; 


da->InsertCommand->ExecuteNonQueryÛO; 


sc->Close); 


private: System::Void button2 Click(System::Object? sender, System::EventArgs? e) { 


da->SelectCommand = gcnew SqlCommand("SELECT * FROM MyTable",sc); 
ds->Clear(); 

da->Fill(ds); 

dataGridView1->DataSource = ds->Tables[0]; 

bs->DataSource = ds->Tables[0]; 

textBox1->DataBindings-> Add(gcnew Binding("Text",bs, "Username")); 
textBox2->DataBindings-> Add(gcnew Binding("Text",bs,"Password")); 


private: System:: Void button4 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveNext(0; 
Update); 


private: System::Void button3 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveFirst(O; 
Update); 


private: System::Void buttonS Click(System::Object sender, System::EventArgs? e) { 
bs->MovePrevious(); 
Update); 


private: System:: Void button6 Click(System::Object sender, System::EventArgs? e) { 
bs->MoveLast(); 
Update); 


private: void Update) 
{ 
dataGridView1->ClearSelection); 
dataGridView1l->Rows[bs->Position]->Selected = true; 


private: System:: Void button7_ Click(System::Object sender, System::EventArgs? e) { 
da->UpdateCommand = gcnew SqlCommand("UPDATE MyTable SET Username =@Username,Password = 
@Password WHERE ID =@ID"', sc); 
da->UpdateCommand->Parameters->Add("@Username'",SqlDbType::VarChar)->Value = textBox1->Text; 
da->UpdateCommand->Parameters->Add("@Password",Sql1DbType:: VarChar)->Value = textBox2->Text; 
da->UpdateCommand->Parameters->Add("@ID",Sql1DbType::Int)->Value = ds->Tables[0]->Rows[bs->Position][0]; 


sc->OpenÛ; 
da->UpdateCommand->ExecuteNonQuery(Û); 
sc->Close); 


private: System::Void button8 Click(System::Object sender, System::EventArgs? e) { 
da->DeleteCommand = gcnew SqlCommand("Delete FROM MyTable WHERE ID = @ID", sc); 
da->DeleteCommand->Parameters->Add("@ID", SqlDbType::Int)->Value = ds->Tables[0]->Rows[bs->Position][0]; 


sc->OpenÛ; 
da->DeleteCommand->ExecuteNonQuery(Û; 
sc->Close(); 


ds->ClearO; 
da->Fill(ds); 
} 


} 
8 
هذا ما تيسر قوله في هذا الباب ولا شك أن التعامل مع الإس كيو إل يحوي الكثير من المهارات والمعطلبات والتي نويت أن 
أجعها في فصول قواعد البيانات في مصنف ميته بانقراج الكرب فها خفي من معام لغة الي شارب ومثله معه في لغة 
السي بلس بلس وال جافا يسر الله إقام هذا الباب من العلوم ولعله من الحسن ههنا أن أشير إلى العلة من تسمية هذا 
الكتاب بجهد المقل فان الإقلال في الأمر يعني عدم توفیته حقه ولا أراني قد بلغت مدارج المبتدئين في هذا الباب وإنغا هي 
رسالة عاجلة أردت بها أن يكون الأصحاب على دراية بهذا الباب لما له من أهية في سوق البرجيات وأحث قاريء هذه 
الرسالة على البحث في كيفية البحث في قواعد البيانات وكيفية جمع قم صف من الصفوف أو طرحما أو ما سوى ذلك من 
العمليات كالمتوسط وما شايمها وأيضا أحث القاريء على البحث في كيفية تخزين الصور والأصوات والملفات ذات 
الامتدادات الأخرى ومنه أيضا البحث في كفية تحويل محتوى قاعدة بيانات إلى ملف إكسل والعكس فهذه مسائل نويت 
بأمر الله أن أفصل فيا القول في الاتفراج ولم يتسع وقتي للإجمال في هذه الأمور في رسالتي هذه لكيلا تخرج عن مقصدها 
في الاقتصار والاختصار ما أحطت به في هذا العلم ولله الفضل أولا وآخرا اللهم تقبل منا إنك أنت السميع العليم وتب 
علينا إنك نت التواب الرحم الهم إنا فسألك علا نافعا ورزقا طيبا وعملا متقبلا . 
وصل اللهم وسم وبارك على نبینا شمد وعلى آله وصعبه وسم 


فرغ منه الفقير إلى عفو ربه 
الحسن بن حبيب 
في لياة المعة 
الرابع والمشرين من ذي المجة للعام ثلاثين وأربعائة وألف 
من رة النبي صلى الله عليه وعلى آله وسال 


